Rails处理图片上传: CarrierWave
文件上传可以说处处都有,我们在论坛中上传附件,在注册一个新用户时上传头像, 编辑一个文章时要上传图片等等。
使用的基本的文件上传,就可以达到我们想要的目的。 但是,基本的文件上传,有一定的弊端:
- 要把所有的上传文件的 文件名, 服务器上的路径, 要记录下来。
- 如果客户端上传的文件过大, 我们要可以缩放。
- 要不要把文件名处理一下?(去掉汉字?去掉空格?用随机字符串命名?)
为了很方便的解决上面的需求, 我们就使用现成的轮子。 carrierwave CarrierWave(https://github.com/carrierwaveuploader/carrierwave) 用来把客户端上传的图片保存到服务器本地。它支持包括Rails, Sinatra 在内的多种框架。
注意: 以下仅支持 carrierwave 0.9.0 版本. 0.10.0 与 1.0 版本的用法略有变化, 请注意查看官方文档
1.0 版本仅支持 ruby 2.0 与 rails 4 .
使用
in Gemfile:
gem 'carrierwave', '0.9.0'
$ rails generate uploader Logo
会新建一个这样的model:
# this will create file: app/uploaders/logo_uploader.rb
class AvatarUploader < Logo::Uploader::Base
storage :file
end
`
同时, 务必记得 为对应的model 增加 列: logo
# -*- encoding : utf-8 -*-
class AddLogoToMarketModules < ActiveRecord::Migration
def change
add_column :market_modules, :logo, :string, default: '', comment: '保存截图路径'
end
end
in your model:
class MarketModule < ActiveRecord::Base
mount_uploader :logo, LogoUploader
end
in your view:
<%= f.file_field :logo %>
in controller :
your_model = MarketModule.first
# do nothing....
your_model.create(params[:item])
# or
your_model.logo = params[:file]
your_model.save
对于 rails4, 只需要把 avatar 这个属性加入到 参数白名单列表中:
def item_params
params.require(:item).permit(:market_id, :name, :level, :avatar)
end
用法:
<%= image_tag @item.logo.url, :style => 'height: 200px' %>